# V-14 Digital Design diploma

## (Ninja Turtles group)

**Mohamed Emadeldin Ali** 

**Ramadan Khaled Younes** 

**Momen Mostafa Mohamed Elzaghawy** 

\_\_\_\_\_\_

# **SPI Slave with Single Port RAM**

# 1) Questasim snippets:



# 2) Questalint snippets:



## 3) Synthesis Tool:

### a) Elaboration:

- ∨ 

  □ Vivado Commands (3 infos)
  - ∨ 
    ☐ General Messages (3 infos)
    - [IP\_Flow 19-234] Refreshing IP repositories
    - (IP\_Flow 19-1704) No user IP repositories specified
    - f) [IP\_Flow 19-2313] Loaded Vivado IP repository 'D:/Vivado/Vivado/2018.2/data/ip'.
- ∨ 
  □ Elaborated Design (11 infos)
  - ✓ □ General Messages (11 infos)
    - > (1) [Synth 8-6157] synthesizing module 'SPI' [SPI.v:1] (2 more like this)
      - (1) [Synth 8-155] case statement is not full and has no default [SPI\_SLAVE.v:41]
    - > (1 [Synth 8-6155] done synthesizing module 'SPI\_SLAVE' (1#1) [SPI\_SLAVE.v.1] (2 more like this)
      - (1) [Device 21-403] Loading part xc7a35ticpg236-1L
      - (Project 1-570) Preparing netlist for logic optimization
      - 1 [Opt 31-138] Pushed 0 inverter(s) to 0 load pin(s).
      - (f) [Project 1-111] Unisim Transformation Summary: No Unisim elements were transformed.





RAM



# b) synthesis:



- → Synthesis (5 warnings, 32 infos)
  - () [Common 17-349] Got license for feature 'Synthesis' and/or device 'xc7a35ti'
  - > (Synth 8-6157) synthesizing module 'SPI' [SPI.v.1] (2 more like this)
  - [Synth 8-6090] variable 'rd\_add' is written by both blocking and non-blocking assignments, entire logic could be removed [SPI\_SLAVE.v.114]
  - > 1 (Synth 8-6155) done synthesizing module 'SPI\_SLAVE' (1#1) [SPI\_SLAVE.v.1] (2 more like this)
  - (Device 21-403) Loading part xc7a35ticpg236-1L
  - [Project 1-235] Implementation specific constraints were found while reading constraint file [C/Users/MO Emad/Desktop/Digital design diploma V14/SPI project/SPI.xdc]. These constraints will be ignored for synthesis but will be used in implementation. Impacted constraints are listed in the file [XiiISP]\_propimpl.xdc].

    Resolution: To avoid this warning, move constraints listed in [Undefined] to another XDC file and exclude this new file from synthesis with the used\_in\_synthesis property (File Properties dialog in GUI) and re-run elaboration/synthesis.

  - 1 [Synth 8-802] inferred FSM for state register 'cs\_reg' in module 'SPI\_SLAVE' > (Synth 8-5544) ROM "rd\_add" won't be mapped to Block RAM because address size (3) smaller than threshold (5) (6 more like this)
  - > 0 [Synth 8-327] inferring latch for variable 'FSM\_sequential\_ns\_reg' [SPI\_SLAVE.v:40] (2 more like this
  - (1) [Synth 8-3354] encoded FSM with state register 'cs\_reg' using encoding 'one-hot' in module 'SPI\_SLAVE'
  - > 6 [Synth 8-6430] The Block RAM mem\_reg may get memory collision error if read and write address collide. Use attribute (\* rw\_addr\_collision= 'yes' \*) to avoid collision (1 more like this)
  - (Project 1-571) Translating synthesized netlist
  - 1 [Netlist 29-17] Analyzing 11 Unisim elements for replacement
  - (Netlist 29-28) Unisim Transformation completed in 0 CPU seconds
  - > (project 1-570) Preparing netlist for logic optimization (1 more like this)
  - (Opt 31-138) Pushed 0 inverter(s) to 0 load pin(s).
  - > (a) [Project 1-111] Unisim Transformation Summary:
    No Unisim elements were transformed. (1 more like this)

  - () [Common 17-83] Releasing license: Synthesis
  - () [Constraints 18-5210] No constraint will be written out.
  - n [Common 17-1381] The checkpoint 'C/Users/MO Emad/Desktop/Digital design diploma V14/SPI project/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/1/project/
  - 1 [runtcl-4] Executing : report\_utilization -file SPI\_utilization\_synth.rpt -pb SPI\_utilization\_synth.pb
  - 1 [Common 17-206] Exiting Vivado at Fri Mar 14 23:50:17 2025...
- ∨ 

  □ Synthesized Design (9 infos)
- ∨ 
  ☐ General Messages (9 infos)
  - (Netlist 29-17) Analyzing 6 Unisim elements for replacement
  - [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
  - 1 [Project 1-479] Netlist was created with Vivado 2018.2
  - 1 [Project 1-570] Preparing netlist for logic optimization
  - (Opt 31-138) Pushed 0 inverter(s) to 0 load pin(s).

  - [Project 1-111] Unisim Transformation Summary:
     No Unisim elements were transformed.
     [Timing 38-35] Done setting XDC timing constraints.
  - 1 [Timing 38-91] UpdateTimingParams: Speed grade: -1L, Delay Type: min\_max
  - f [Timing 38-191] Multithreading enabled for timing update using a maximum of 2 CPUs

#### Figure 1

| Name 1                        | Slice LUTs<br>(20800) | Slice Registers<br>(41600) | F7<br>Muxes<br>(16300) | Block RAM Tile<br>(50) | Bonded IOB<br>(106) | BUFGCTRL<br>(32) |
|-------------------------------|-----------------------|----------------------------|------------------------|------------------------|---------------------|------------------|
| ∨ N SPI                       | 67                    | 57                         | 1                      | 0.5                    | 5                   | 1                |
| dbg_hub (dbg_hub_CV)          | 0                     | 0                          | 0                      | 0                      | 0                   | 0                |
| M1 (SPI_SLAVE)                | 65                    | 40                         | 0                      | 0                      | 0                   | 0                |
| ■ M2 (RAM)                    | 2                     | 9                          | 1                      | 0.5                    | 0                   | 0                |
| <b>■ u_ila_0</b> (u_ila_0_CV) | 0                     | 0                          | 0                      | 0                      | 0                   | 0                |

# <u>i – gray-FSM-encoding :</u>

#### **Design Timing Summary**

| Setup                             |              | Hold                         |          | Pulse Width                                       |
|-----------------------------------|--------------|------------------------------|----------|---------------------------------------------------|
| Worst Negative Slack (WNS):       | 6.182 ns     | Worst Hold Slack (WHS):      | 0.139 ns | Worst Pulse Width Slack (WPWS): 4.500 ns          |
| Total Negative Slack (TNS):       | 0.000 ns     | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): 0.000 ns |
| Number of Failing Endpoints:      | 0            | Number of Failing Endpoints: | 0        | Number of Failing Endpoints: 0                    |
| Total Number of Endpoints:        | 108          | Total Number of Endpoints:   | 108      | Total Number of Endpoints: 55                     |
| II user specified timing constrai | nts are met. |                              |          |                                                   |

### ii - one-hot-FSM-encoding:

#### **Design Timing Summary**

| etup                         |          | Hold                         |          | Pulse Width                              |          |  |
|------------------------------|----------|------------------------------|----------|------------------------------------------|----------|--|
| Worst Negative Slack (WNS):  | 6.182 ns | Worst Hold Slack (WHS):      | 0.139 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |  |
| Total Negative Slack (TNS):  | 0.000 ns | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |  |
| Number of Failing Endpoints: | 0        | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |  |
| Total Number of Endpoints:   | 108      | Total Number of Endpoints:   | 108      | Total Number of Endpoints:               | 55       |  |

### iii - seq-FSM-encoding:

#### **Design Timing Summary**

| Setup                             |              | Hold                         |          | Pulse Width                              |          |  |
|-----------------------------------|--------------|------------------------------|----------|------------------------------------------|----------|--|
| Worst Negative Slack (WNS):       | 6.182 ns     | Worst Hold Slack (WHS):      | 0.139 ns | Worst Pulse Width Slack (WPWS):          | 4.500 ns |  |
| Total Negative Slack (TNS):       | 0.000 ns     | Total Hold Slack (THS):      | 0.000 ns | Total Pulse Width Negative Slack (TPWS): | 0.000 ns |  |
| Number of Failing Endpoints:      | 0            | Number of Failing Endpoints: | 0        | Number of Failing Endpoints:             | 0        |  |
| Total Number of Endpoints:        | 108          | Total Number of Endpoints:   | 108      | Total Number of Endpoints:               | 55       |  |
| II user specified timing constrai | nts are met. |                              |          |                                          |          |  |

# c) Implementation:



- implemented Design (1 warning, 10 infos)
- General Messages (1 warning, 10 infos)
  - (1) [Netlist 29-17] Analyzing 96 Unisim elements for replacement
  - (1) [Netlist 29-28] Unisim Transformation completed in 0 CPU seconds
  - (Project 1-479) Netlist was created with Vivado 2018.2
  - (Project 1-570) Preparing netlist for logic optimization
  - (Chipscope 16-324) Core: u\_ila\_0 UUID: 23e7d65a-79bc-59f7-bc47-406c1714dfae
  - (1) [Timing 38-478] Restoring timing data from binary archive.
  - (1) [Timing 38-479] Binary timing data restore complete.
  - (Project 1-856) Restoring constraints from binary archive.
  - (Project 1-853) Binary constraint restore complete.
  - [6] [Project 1-111] Unisim Transformation Summary: A total of 50 instances were transformed. CFGLUT5 => CFGLUT5 (SRLC32E, SRL16E): 44 instances RAM32M => RAM32M (RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMD32, RAMS32): 6 instances



## d) Generation of bitstream file:

